對于使用中的已有了一些數據庫的 MySQL, 如何改造成雙主呢? 這里寫一篇文章, 詳細記錄操作步驟. 聽取各位的意見.
這里假設有兩臺服務器: A 和 B. 要讓他們互為主, 但實際使用時, 不同的服務器只服務不同的 db, 避免出現數據沖突.
1. 修改 nginx 配置, 掛維護頁
這一步很重要. 你需要告訴你的用戶, 你的網站在維護, 同時要確保不會再出現數據庫寫操作.
另外, 還要停止 crontab 任務.
2. 備份數據庫
Server A:
mysqldump-uroot-p--all-databases>a_dbdump_all.sql
gzip a_dbdump_all.sql
Server B:
mysqldump-uroot-p--all-databases>b_dbdump_all.sql
gzip b_dbdump_all.sql
把線上數據庫備份到本地
scp test@server_a:~/a_dbdump_all.sql.gz.scp test@server_b:~/b_dbdump_all.sql.gz.
3. 新建數據庫同步賬號
Server A:
GRANT REPLICATION SLAVE ON*.*TO'userx'@'server_b'IDENTIFIED BY'xxxxx';
Server B:
GRANT REPLICATION SLAVE ON*.*TO'userx'@'server_a'IDENTIFIED BY'xxxxx';
4. 導數據
這一步是手工將兩臺服務器數據庫(基準數據)同步.
Server A:
mysqldump-uroot-p--databases db1>a_dbdump.sql
scp a_dbdump.sql test@server_b:~
Server B:
mysqldump-uroot-p--databases db2>b_dbdump.sql
scp b_dbdump.sql test@server_a:~
Server A:
source b_dbdump.sql
Server B:
source a_dbdump.sql
5. 修改 mysql 配置
Server A:
[mysqld]server-id=1log-bin=mysql-bin
log-slave-updates
binlog-ignore-db=mysql
binlog-ignore-db=test
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
replicate-ignore-db=mysql
replicate-ignore-db=test
replicate-ignore-db=information_schema
replicate-ignore-db=performance_schema
master-connect-retry=10ServerB:[mysqld]server-id=2log-bin=mysql-bin
log-slave-updates
binlog-ignore-db=mysql
binlog-ignore-db=test
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
replicate-ignore-db=mysql
replicate-ignore-db=test
replicate-ignore-db=information_schema
replicate-ignore-db=performance_schema
master-connect-retry=10
注意, 他們的 server-id 不相同.
6. 重啟 MySQL, 測試同步賬號可用
重啟 MySQL.
Server A:
mysql-hserver_b-uuserx-pxxxxx
Server B:
mysql-hserver_a-uuserx-pxxxxx
7. 啟動 Slave 線程
Server A:
FLUSH TABLES;show master status;
會顯示這樣的信息.
***************************1.row***************************File:mysql-bin.000001Position:106Binlog_Do_DB:Binlog_Ignore_DB:mysql,test,information_schema,performance_schema1rowinset(0.00sec)
記錄 File 和 Position, 這時 binlog 的當前位置, 因為 Slave 要從這個位置開始同步數據.
Server B:
CHANGE MASTER TO MASTER_HOST='server_a';CHANGE MASTER TO MASTER_USER='userx';CHANGE MASTER TO MASTER_PASSWORD='xxxxx';CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=106;start slave;show slave status\G
同樣的, 在 Server A 上也啟動同步 Slave 進程.
因為我們確保了沒有數據庫寫操作, 所以不需要 FLUSH TABLES WITH READ LOCK;.
8. 驗證
在不同的數據庫上執行一些更新數據的操作, 看看數據是否同步過去了.
9. 完成
恢復 crontab 任務
修改 nginx, 撤下維護網頁, 恢復服務